package com.ybkj.daijia.server.mapper;

import com.ybkj.daijia.server.model.Announcement;
import java.util.List;
import org.apache.ibatis.annotations.Param;

public interface AnnouncementMapper {

    /**
     * 保存公告信息到数据库
     *
     * @param record
     * @return 保存成功返回Id信息
     */
    Long insertAnnouncement(Announcement record);

    /**
     * 根据主键查询公告信息
     *
     * @param id
     * @return
     */
    Announcement selectByPrimaryKey(Long id);

    /**
     * 根据一组主键查询公告信息
     *
     * @param ids
     * @return
     */
    List<Announcement> selectByIdIn(Long[] ids);

    /**
     * 根据主键删除公告信息
     *
     * @param id
     * @return 返回影响的行数
     */
    int deleteByPrimaryKey(Long id);

    /**
     * 分页查询公告信息
     *
     * @param companyId
     * @param offset
     * @param size
     * @return
     */
    List<Announcement> selectByCompany(@Param("companyId") Long companyId,
        @Param("offset") Integer offset, @Param("size") Integer size);

    /**
     * 统计公告信息
     */
    Long countByCompany(@Param("companyId") Long companyId);

    /**
     * 并且查询出companyId为空的公告
     */
    List<Announcement> selectByCompanyIdOrNull(@Param("companyId") Long companyId,
        @Param("offset") Integer offset, @Param("size") Integer size);

    /**
     * 并且统计出companyId为空的公告
     */
    Long countByCompanyIdOrNull(@Param("companyId") Long companyId);

    /**
     * 根据主键修改数据
     *
     * @param record
     * @return
     */
    int updateByPrimaryKey(Announcement record);

}
